package com.zxy.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.zxy.pojo.entity.*;

import com.zxy.pojo.dto.BusinessQueryDTO;
import com.zxy.pojo.vo.CustomerDetailVO;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.data.repository.query.Param;

import java.util.List;

@Mapper
public interface OpportunityMapper extends BaseMapper<CustomerClue> {
    /**
     * 分页查询商机列表
     */
    List<CustomerClue> selectBusinessList(@Param("query") BusinessQueryDTO query);

    /**
     * 查询总记录数
     */
    Long countBusinessList(@Param("query") BusinessQueryDTO query);

    /**
     *  查询商机记录列表
     * @param businessId
     * @return
     */
    List<BusinessRecord> selectByBusinessId(Long businessId);



    /**
     * 添加商机记录
     * @param record
     * @return
     */
    int addRecord(BusinessRecord record);


    /**
     * 根据用户ID统计已分配的线索数量
     * @param userId
     * @return
     */
    int countAssignClueByUser(Long userId);

    /**
     * 根据线索ID查询线索信息
     * @param clueId
     * @return
     */


    CustomerClue selectClueById(Long clueId);

    /**
     * 修改商机
     * @param clue
     * @return
     */
    void updateClue(CustomerClue clue);

    /**
     * 添加商机分配记录
     * @param assignRecord
     * @return
     */
    int insertAssignRecord(ClueAssignRecord assignRecord);


    /**
     * 这个是待跟进部分的修改
     * @param customerClue
     */
    void updateClues(CustomerClue customerClue);


    /**
     * 查询商机详情
     * @param id
     * @return
     */
    CustomerDetailVO getCustomerDetailById(Long id);

    /**
     * 查询可分配的商机列表
     * @return
     */
    List<CustomerClue> selectAvailableBusiness();

    /**
     * 查询用户已分配的商机数量
     * @param userId
     * @return
     */
    int countAssignedBusiness(@Param("userId") Long userId);

}
